<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <div id="app">
    <div>{{ message }}</div>
    <div>{{ reversedMessage }}</div>
    <div>{{ reversedMessage }}</div>
    <div>{{ reversedMessage }}</div>
    <div>{{ reversedMessage }}</div>
    <div>{{ reversedMessage }}</div>
    <div>{{ reversedMessage }}</div>
    <div>{{ reversedMessage }}</div>
    <div>{{ reversedMessage }}</div>
  </div>

  <script src="./libs/vue.js"></script>
  <script>
    const vm = new Vue({
      el: '#app',
      data: {
        message: 'hello'
      },
      // 计算属性
      computed: {
        // 这种计算属性的书写方式，相当于是 getter() 方法的简写形式
        reversedMessage() {
          console.log('计算...')
          return this.message.split('').reverse().join('')
        }
        // // 了解，完整写法
        // reversedMessage: {
        //   get() { // getter，主要用于返回该属性（reversedMessage） 的值
        //     return this.message.split('').reverse().join('')
        //   },
        //   set(val) { // setter，主要用于设置属性值
        //     this.message = val.split('').reverse().join('')
        //   }
        // }
      }
    })
  </script>
</body>
</html>